<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>芝士erp商品管理</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="stylesheet" href="/resources/layui/css/layui.css" media="all"/>
    <link rel="stylesheet" href="/resources/css/public.css" media="all"/>
</head>
<body class="childrenBody">
<!--query condition start-->
<fieldset class="layui-elem-field layui-field-title" style="margin-top: 5px;">
    <legend>查询条件</legend>
</fieldset>
<blockquote class="layui-elem-quote">
    <form action="" method="post" id="searchForm" lay-filter="searchForm" class="layui-form layui-form-pane">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">供应商</label>
                <div class="layui-input-inline">
                    <select name="providerid" id="search_providerid"></select>
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">商品名称</label>
                <div class="layui-input-inline">
                    <input type="text" name="goodsname" autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">生产批号</label>
                <div class="layui-input-inline">
                    <input type="text" name="productcode" autocomplete="off" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">批准文号</label>
                <div class="layui-input-inline">
                    <input type="text" name="promitcode" autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">商品描述</label>
                <div class="layui-input-inline">
                    <input type="text" name="description" autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">商品规格</label>
                <div class="layui-input-inline">
                    <input type="text" name="size" autocomplete="off" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: right;">
                <button type="button" class="layui-btn layui-btn-sm" lay-submit="" lay-filter="doSearch"><span
                        class="layui-icon layui-icon-search"></span>查询
                </button>
                <button type="reset" class="layui-btn layui-btn-warm layui-btn-sm"
                        onclick="javascript:document.getElementById('search_providerid').value=null"><span
                        class="layui-icon layui-icon-refresh-1"></span>重置
                </button>
            </div>
        </div>
    </form>
</blockquote>
<!--query condition end-->

<!--form start-->
<div>
    <div id="goodsToolBar" style="display: none;">
        <button type="button" lay-event="addGoods" class="layui-btn layui-btn-sm">
            <span class="layui-icon layui-icon-add-1"></span>添加商品
        </button>
        <button type="button" lay-event="batchDeleteGoods" class="layui-btn layui-btn-sm layui-btn-danger"><span
                class="layui-icon layui-icon-delete"></span>批量删除
        </button>
    </div>

    <table class="layui-hide" id="goodsTable" lay-filter="goodsTable"></table>

    <div id="goodsRowBar" style="display: none;">
        <button type="button" lay-event="updateGoods" class="layui-btn layui-btn-sm"><span
                class="layui-icon layui-icon-edit"></span>更新
        </button>
        <button type="button" lay-event="deleteGoods" class="layui-btn layui-btn-sm layui-btn-danger"><span
                class="layui-icon layui-icon-delete"></span>删除
        </button>
    </div>
</div>
<!--form end-->

<!--富文本界面的隐藏和弹出-->
<div style="display: none;padding: 5px" id="addOrUpdateDiv">
    <form action="" method="post" id="dataForm" lay-filter="dataForm"
          class="layui-form layui-row layui-col-space10 layui-form-pane">
        <div class="layui-col-md12 layui-col-xs12">
            <div class="layui-row layui-col-space10">
                <div class="layui-col-md9 layui-col-xs7">
                    <div class="layui-form-item magt3">
                        <label class="layui-form-label layui-bg-gray">供应商</label>
                        <div class="layui-input-block">
                            <input type="hidden" name="id">
                            <select name="providerid" required lay-verify="required" id="submit_providerid"></select>
                        </div>
                    </div>
                    <div class="layui-form-item">
                        <label class="layui-form-label layui-bg-gray">商品名称</label>
                        <div class="layui-input-block">
                            <input type="text" name="goodsname" lay-verify="required" autocomplete="off"
                                   class="layui-input"
                                   placeholder="请输入商品名称">
                        </div>
                    </div>
                    <div class="layui-form-item">
                        <label class="layui-form-label layui-bg-gray">商品描述</label>
                        <div class="layui-input-block">
                            <input type="text" name="description" lay-verify="required" autocomplete="off"
                                   class="layui-input"
                                   placeholder="请输入商品描述">
                        </div>
                    </div>
                </div>
                <div class="layui-col-md3 layui-col-xs5">
                    <div class="layui-upload-list thumbBox mag0 magt3">
                        <input type="hidden" name="goodsimg" id="goodsimg" value="images/defaultgoodsimg.png">
                        <img class="layui-upload-img thumbImg"
                             src="/file/showImageByPath?path=images/defaultgoodsimg.png">
                    </div>
                </div>
            </div>
            <div class="layui-form-item magb0">
                <div class="layui-inline">
                    <label class="layui-form-label layui-bg-gray">生产地址</label>
                    <div class="layui-input-inline">
                        <input type="text" name="produceplace" lay-verify="required" autocomplete="off"
                               class="layui-input"
                               placeholder="请输入生产地址">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label layui-bg-gray">商品包装</label>
                    <div class="layui-input-inline">
                        <input type="text" name="goodspackage" lay-verify="required" autocomplete="off"
                               class="layui-input"
                               placeholder="请输入商品包装">
                    </div>
                </div>
            </div>
            <div class="layui-form-item magb0">
                <div class="layui-inline">
                    <label class="layui-form-label layui-bg-gray">商品规格</label>
                    <div class="layui-input-inline">
                        <input type="text" name="size" lay-verify="required" autocomplete="off" class="layui-input"
                               placeholder="请输入商品规格">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label layui-bg-gray">生产批号</label>
                    <div class="layui-input-inline">
                        <input type="text" name="productcode" lay-verify="required" autocomplete="off"
                               class="layui-input"
                               placeholder="请输入生产批号">
                    </div>
                </div>
            </div>
            <div class="layui-form-item magb0">
                <div class="layui-inline">
                    <label class="layui-form-label layui-bg-gray">批准文号</label>
                    <div class="layui-input-inline">
                        <input type="text" name="promitcode" lay-verify="required" autocomplete="off"
                               class="layui-input"
                               placeholder="请输入批准文号">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label layui-bg-gray">商品价格</label>
                    <div class="layui-input-inline">
                        <input type="text" name="price" lay-verify="required" autocomplete="off" class="layui-input"
                               placeholder="请输入商品价格">
                    </div>
                </div>
            </div>
            <div class="layui-form-item magb0">
                <div class="layui-inline">
                    <label class="layui-form-label layui-bg-gray">商品数量</label>
                    <div class="layui-input-inline">
                        <input type="text" name="number" lay-verify="required" autocomplete="off" class="layui-input"
                               placeholder="请输入商品数量">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label layui-bg-gray">商品预警值</label>
                    <div class="layui-input-inline">
                        <input type="text" name="dangernum" lay-verify="required" autocomplete="off" class="layui-input"
                               placeholder="请输入商品预警值">
                    </div>
                </div>
            </div>
            <div class="layui-form-item magb0">
                <div class="layui-inline">
                    <label class="layui-form-label layui-bg-gray">是否可用</label>
                    <div class="layui-input-inline">
                        <input type="radio" name="available" value="1" title="可用" checked="">
                        <input type="radio" name="available" value="0" title="不可用">
                    </div>
                </div>
            </div>

            <div class="layui-form-item">
                <div class="layui-input-block" style="text-align: right;">
                    <button type="button" class="layui-btn layui-btn-sm" lay-submit="" lay-filter="doSubmit"
                            id="doSubmit"><span
                            class="layui-icon layui-icon-add-1"></span>提交
                    </button>
                    <button type="reset" class="layui-btn layui-btn-warm layui-btn-sm"><span
                            class="layui-icon layui-icon-refresh-1"></span>重置
                    </button>

                </div>
            </div>
        </div>
    </form>
</div>

<script type="text/javascript" src="/resources/layui/layui.js"></script>
<script type="text/javascript" th:inline="none">
    layui.use(['jquery', 'table', 'form', 'layer', 'laydate', 'layedit', 'upload'], function () {
        var $ = layui.jquery;
        var table = layui.table;
        var form = layui.form;
        var layer = layui.layer;
        var laydate = layui.laydate;
        var layedit = layui.layedit;
        var upload = layui.upload;

        //加载数据
        var tableIns = table.render({
            elem: '#goodsTable',
            url: '/goods/loadAllGoods',
            toolbar: '#goodsToolBar', //开启头部工具栏
            title: '商品数据表',
            height: 'full-222',
            page: true,
            cols: [[
                {type: 'checkbox', fixed: 'left'},
                {field: 'id', title: 'ID', align: 'center', width: "80"},
                {field: 'goodsname', title: '商品名称', align: 'center', width: "150"},
                {field: 'providername', title: '供应商', align: 'center', width: "150"},
                {field: 'produceplace', title: '生产地址', align: 'center', width: "100"},
                {field: 'size', title: '商品规格', align: 'center', width: "100"},
                {field: 'goodspackage', title: '商品包装', align: 'center', width: "100"},
                {field: 'productcode', title: '生产批号', align: 'center', width: "150"},
                {field: 'promitcode', title: '批准文号', align: 'center', width: "150"},
                {field: 'description', title: '商品描述', align: 'center', width: "150"},
                {field: 'price', title: '商品价格', align: 'center', width: "100"},
                {field: 'number', title: '商品数量', align: 'center', width: "100"},
                {field: 'dangernum', title: '商品预警值', align: 'center', width: "100"},
                {
                    field: 'goodsimg', title: '图片地址', align: 'center', width: "200", templet: function (d) {
                        return '<img width=40 height=40 src=/file/showImageByPath?path=' + d.goodsimg + ' alt=""/>';
                    }
                },
                {
                    field: 'available', title: '是否可用', align: 'center', width: '100', templet: function (d) {
                        return d.available == 1 ? '<font color=blue>可用</font>' : '<font color=red>不可用</font>';
                    }
                },
                {fixed: 'right', title: '操作', toolbar: '#goodsRowBar', align: 'center', width: "250"}
            ]],
            //done:数据渲染完的回调，你可以借此做一些其他的操作
            done: function (res, curr, count) {//处理删除最后一页的bug
                if (res.data.length == 0 && curr != 1) {
                    tableIns.reload({
                        page: {
                            curr: (curr - 1)
                        }
                    });
                }
            }
        });

        //模糊查询
        form.on("submit(doSearch)", function (data) {
            tableIns.reload({
                where: data.field,
                page: {
                    curr: 1
                }
            });
            return false;
        });

        //监听数据表格顶部的工具条
        table.on("toolbar(goodsTable)", function (obj) {
            switch (obj.event) {
                case 'batchDeleteGoods':
                    batchDeleteGoods();
                    break;
                case 'addGoods':
                    addGoods();
                    break;
            }
        });
        //监听数据表格当中的行工具条
        table.on("tool(goodsTable)", function (obj) {
            switch (obj.event) {
                case 'deleteGoods':
                    deleteGoods(obj.data);
                    break;
                case 'updateGoods':
                    updateGoods(obj.data);
                    break;
            }
        });

        var mainIndex;
        var url;

        function addGoods() {
            mainIndex = layer.open({
                type: 1,
                content: $("#addOrUpdateDiv"),
                area: ['800px', '500px'],
                title: '发布商品',
                success: function () {
                    $("#dataForm")[0].reset();
                    // layedit.setContent(editIndex, "");
                    url = "/goods/addGoods";
                    //加载添加商品中供应商的下拉列表
                    $.get("/goods/loadAllProviderForSelect", function (res) {
                        var data = res.data;
                        var dom = $("#submit_providerid");
                        var html = '<option value="0">请选择供应商</option>'
                        $.each(data, function (index, item) {
                            html += '<option value="' + item.id + '">' + item.providername + '</option>'
                        })
                        dom.html(html);
                        form.render("select");
                    })
                    //设置默认图片
                    $(".thumbImg").attr("src", '/file/showImageByPath?path=images/defaultgoodsimg.png');
                    $("#goodsimg").val("images/defaultgoodsimg.png");
                }
            })
        }

        function updateGoods(data) {
            mainIndex = layer.open({
                type: 1,
                content: $("#addOrUpdateDiv"),
                area: ['800px', '500px'],
                title: '修改商品',
                success: function () {
                    $('#dataForm')[0].reset();
                    //装载新的数据
                    form.val("dataForm", data);
                    url = "/goods/updateGoods";
                    //加载查询条件供应商的下拉列表
                    $.get("/goods/loadAllProviderForSelect", function (res) {
                        var redata = res.data;
                        var dom = $("#submit_providerid");
                        var html = '<option value="0">请选择供应商</option>'
                        $.each(redata, function (index, item) {
                            if (data.providerid === item.id) {
                                html += '<option value="' + item.id + '" selected>' + item.providername + '</option>'
                            } else {
                                html += '<option value="' + item.id + '">' + item.providername + '</option>'
                            }
                        })
                        dom.html(html);
                        form.render("select");
                    });
                    $(".thumbImg").attr("src", '/file/showImageByPath?path=' + data.goodsimg);
                }
            })
        }

        $("#doSubmit").click(function () {
            var data = $("#dataForm").serialize();
            if (data.split("&")[1].split("=")[1] === "" || data.split("&")[2].split("=")[1] === "") {
                //此处无需打印，lay-verify会自动弹出提示信息，当然也可以打印。
                //例如layer.msg("标题或内容为空，无法提交！")
            } else {
                $.post(url, data, function (res) {
                    if (res.code === 200) {
                        tableIns.reload();
                    }
                    layer.msg(res.msg);
                    layer.close(mainIndex);
                })
            }
        })

        function batchDeleteGoods() {
            var checkStatus = table.checkStatus('goodsTable');
            var dataLength = checkStatus.data.length;
            if (dataLength > 0) {
                layer.confirm('你确定要删除这些商品？', {icon: 3, title: '提示'}, function (index) {
                    var data = checkStatus.data;
                    var ids = "";
                    var goodsimgs = "";
                    $.each(data, function (index, item) {
                        if (index === 0) {
                            ids += 'ids=' + item.id;
                            goodsimgs += 'goodsimgs=' + item.goodsimg;
                        } else {
                            ids += '&ids=' + item.id;
                            goodsimgs += '&goodsimgs=' + item.goodsimg;
                        }
                    });
                    $.post('/goods/batchDeleteGoods', ids + "&" + goodsimgs, function (res) {
                        if (res.code === 200) {
                            tableIns.reload();
                        }
                        layer.msg(res.msg);
                    })
                    layer.close(index);
                })
            } else {
                layer.msg("请选中操作行！")
            }

        }

        function deleteGoods(data) {
            layer.confirm("你确定要删除【" + data.goodsname + "】这个商品吗？", {icon: 3, title: '标题'}, function (index) {
                $.post('/goods/deleteGoodsById', {id: data.id, goodsimg: data.goodsimg}, function (res) {
                    if (res.code === 200) {
                        tableIns.reload();
                    }
                    layer.msg(res.msg);
                })
                layer.close(index);
            })
        }

        //加载查询条件供应商的下拉列表
        $.get("/goods/loadAllProviderForSelect", function (res) {
            var data = res.data;
            var dom = $("#search_providerid");
            var html = '<option value="0">请选择供应商</option>'
            $.each(data, function (index, item) {
                html += '<option value="' + item.id + '">' + item.providername + '</option>'
            })
            dom.html(html);
            form.render("select");
        })

        //文件上传
        upload.render({
            elem: '.thumbBox',
            url: '/file/uploadFile',
            acceptMime: 'image/*',
            field: 'mf',
            method: "post",  //此处是为了演示之用，实际使用中请将此删除，默认用post方式提交
            done: function (res, index, upload) {
                var path = res.path;
                $('.thumbImg').attr('src', '/file/showImageByPath?path=' + path);
                $('.thumbBox').css("background", "#fff");
                $("#goodsimg").val(path);//给隐藏域赋值
            }
        });
    })
</script>

</body>
</html>